草庐IT

php - 以标题行为键的 CSV 到 Json

全部标签

ruby-on-rails - 如何将 ActiveRecord 模型数组转换为 CSV?

我有一组ActiveRecord模型,我希望将其转换为CSV。我尝试研究像FasterCSV这样的gem,但它们似乎只适用于字符串和数组,而不适用于ActiveRecord模型。简而言之,我要转换:user1=User.firstuser2=User.lasta=[user1,user2]收件人:id,username,bio,email1,user1,user1bio,user1email1,user2,user2bio,user2email有没有简单的Rails方法可以做到这一点? 最佳答案 下面将所有用户的属性写入一个文件:C

Ruby 帖子标题 slug

我应该如何将帖子标题转换为Ruby中的slug?标题可以有任何字符,但我只希望slug允许[a-z0-9-_](它应该允许任何其他字符吗?)。所以基本上:小写所有字母将空格转换为连字符删除多余的字符 最佳答案 这是Rails吗?(适用于Sinatra)string.parameterize就是这样。有关更复杂的重击,请参阅ActsAsUrl.它可以执行以下操作:"rock&roll".to_url=>"rock-and-roll""$12worthofRubypower".to_url=>"12-dollars-worth-of-r

ruby-on-rails - 扩展 Devise SessionsController 以使用 JSON 进行身份验证

我正在尝试为iPhone应用构建一个RailsAPI。Devise可以很好地通过Web界面登录,但我需要能够使用RESTAPI创建和销毁session,我想使用JSON而不是必须在sessionController上执行POST并解析HTML并处理一个重定向。我以为我可以做这样的事情:classApi::V1::SessionsController我在config/routes.rb中添加了:namespace:apidonamespace:v1doresources:sessions,:only=>[:create,:destroy]endendrakeroutes显示路由设置正确:

ruby - 使用 Ruby 将大写字符串转换为标题大小写

我正在尝试将Ruby中的全大写字符串转换为小写字符串,但每个单词的第一个字符都是大写。示例:将“我的字符串在这里”转换为“我的字符串在这里”。我知道我可以使用.downcase方法,但这会使所有内容都变成小写(“我的字符串在这里”)。我正在扫描文件中的所有行并进行此更改,那么是否有可以通过ruby​​使用的正则表达式来实现此目的?谢谢! 最佳答案 如果您正在使用Rails(您真正需要的只是ActiveSupport,它是Rails的一部分),您可以使用titleize:"MYSTRINGHERE".titleize#=>"MyStr

Ruby CSV - 获取当前行/行号

我正在尝试弄清楚如何从RubyCSV中获取当前行/行号。这是我的代码:options={:encoding=>'UTF-8',:skip_blanks=>true}CSV.foreach("data.csv",options,)do|row,i|putsiend但这似乎并没有按预期工作。有办法做到这一点吗? 最佳答案 由于当前Rubies中CSV的更改,我们需要进行一些更改。在2.6之前使用Ruby的原始解决方案的答案中进一步查看。以及with_index的使用,无论版本如何,它都可以继续工作。对于2.6+这将有效:require'

ruby - 使用 Ruby CSV 更改导出的 CSV 中的字段分隔符/定界符

是否可以将默认字段分隔符从逗号更改为其他字符,例如用于导出的'|'? 最佳答案 下面是一个使用选项卡的示例。到一个文件:CSV.open("myfile.csv","w",{:col_sep=>"\t"})do|csv|csv到一个字符串:csv_string=CSV.generate(:col_sep=>"\t")do|csv|csv这是关于CSV的当前文档:http://ruby-doc.org/stdlib/libdoc/csv/rdoc/index.html 关于ruby-使用R

Ruby 将 CSV 文件读取为 UTF-8 和/或将 ASCII-8Bit 编码转换为 UTF-8

我正在使用ruby1.9.2我正在尝试解析包含一些法语单词(例如spécifié)的CSV文件,并将内容放入MySQL数据库中。当我从CSV文件中读取行时,file_contents=CSV.read("csvfile.csv",col_sep:"$")返回的元素是ASCII-8BIT编码的字符串(spécifié变为sp\xE9cifi\xE9),然后像“spécifié”这样的字符串没有正确保存到我的MySQL数据库中。YehudaKatz表示ASCII-8BIT实际上是“二进制”数据,这意味着CSV不知道如何读取适当的编码。所以,如果我尝试让CSV强制编码如下:file_cont

ruby - 检查哈希的键是否包含一组键的所有

我正在寻找更好的方法ifhash.key?:a&&hash.key?:b&&hash.key?:c&&hash.key?:d最好是类似的东西hash.includes_keys?[:a,:b,:c,:d]我想到了hash.keys&[:a,:b,:c,:d]==[:a,:b,:c,:d]但我不喜欢两次添加数组 最佳答案 %i[abcd].all?{|s|hash.key?s} 关于ruby-检查哈希的键是否包含一组键的所有,我们在StackOverflow上找到一个类似的问题:

ruby - 导入csv数据时,如何去掉 "invalid byte sequence in UTF-8"

我们允许用户通过csv导入数据(使用ruby​​1.9.2,因此它是更快的csv)。作为用户数据,当然,它可能没有得到适当的清理。当我们尝试在/index方法中显示数据时,我们有时会收到错误“UTF-8中的无效字节序列”,指向我们显示字段widget.name之一的erb当我们进行导入时,我们希望强制传入的数据有效...是否有一个ruby​​运算符可以将字符串映射到有效的utf8字符串,例如,类似goodstring=badstring.no_more_invalid_bytes“坏”数据的一个示例是char,它看起来像连字符,但不是常规的ascii连字符。我们更愿意将非utf-8字符

ruby - 解析包含标题字段作为每行属性的 CSV 文件

我想解析一个CSV文件,以便每一行都被视为一个对象,标题行是对象中属性的名称。我可以写这个,但我确定它已经在那里了。这是我的CSV输入:"foo","bar","baz"1,2,3"blah",7,"blam"4,5,6代码看起来像这样:CSV.open('my_file.csv','r')do|csv_obj|putscsv_obj.foo#prints1the1sttime,"blah"2ndtime,etcputscsv.bar#prints2thefirsttime,7the2ndtime,etcend使用Ruby的CSV模块,我相信我只能通过索引访问字段。我认为上面的代码会更